package com.atguigu.exam.controller;


import com.atguigu.exam.common.Result;
import com.atguigu.exam.entity.Banner;
import com.atguigu.exam.service.BannerService;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;


import java.util.List;


/**
 * 轮播图控制器 - 处理轮播图管理相关的HTTP请求
 * 包括图片上传、轮播图的CRUD操作、状态切换等功能
 */
@RestController  // REST控制器，返回JSON数据
@RequestMapping("/api/banners")  // 轮播图API路径前缀
@CrossOrigin  // 允许跨域访问
@Tag(name = "轮播图管理", description = "轮播图相关操作，包括图片上传、轮播图增删改查、状态管理等功能")  // Swagger API分组
@Slf4j
public class BannerController {

    @Autowired
    private BannerService bannerService;

    /**
     * 上传轮播图图片
     *
     * @param file 图片文件
     * @return 图片访问URL
     */
    @PostMapping("/upload-image")  // 处理POST请求
    @Operation(summary = "上传轮播图图片", description = "将图片文件上传到MinIO服务器，返回可访问的图片URL")  // API描述
    public Result<String> uploadBannerImage(
            @Parameter(description = "要上传的图片文件，支持jpg、png、gif等格式，大小限制5MB")
            @RequestParam("file") MultipartFile file) throws Exception {
        //调用service上传业务！返回回显地址！
        String url = bannerService.uploadBannerImage(file);
        log.info("上传轮播图图片成功！ 回显地址为：{}", url);
        return Result.success(url, "图片上传成功");
    }

    /**
     * 获取启用的轮播图（前台首页使用）
     *
     * @return 轮播图列表
     */
    @GetMapping("/active")  // 处理GET请求
    @Operation(summary = "获取启用的轮播图", description = "获取状态为启用的轮播图列表，供前台首页展示使用")  // API描述
    public Result<List<Banner>> getActiveBanners() {
        //创建LambdWrapper
        LambdaQueryWrapper<Banner> queryWrapper = new LambdaQueryWrapper<>();
        //激活状态
        queryWrapper.eq(Banner::getIsActive, true);
        //顺序 正序
        queryWrapper.orderByAsc(Banner::getSortOrder);
        //执行查询
        List<Banner> bannerList = bannerService.list(queryWrapper);
        log.info("查询所有前台需要的轮播信息业务执行成功！结果为：{}", bannerList);
        return Result.success(bannerList, "查询轮播图集合成功");
    }


    /**
     * 获取所有轮播图（管理后台使用）
     *
     * @return 轮播图列表
     */
    @GetMapping("/list")  // 处理GET请求
    @Operation(summary = "获取所有轮播图", description = "获取所有轮播图列表，包括启用和禁用的，供管理后台使用")  // API描述
    public Result<List<Banner>> getAllBanners() {
        //1.拼接条件，进行排序
        LambdaQueryWrapper<Banner> lambdaQueryWrapper = new LambdaQueryWrapper<>();
        lambdaQueryWrapper.orderByAsc(Banner::getSortOrder);// 根据sort正序排序
        //2.查询所有符合集合
        List<Banner> bannerList = bannerService.list(lambdaQueryWrapper);
        //3.进行结果拼接
        log.info("查询所有后台需要的轮播信息业务执行成功！结果为：{}", bannerList);
        return Result.success(bannerList, "查询轮播图集合成功");
    }


    /**
     * 根据ID获取轮播图
     *
     * @param id 轮播图ID
     * @return 轮播图详情
     */
    @GetMapping("/{id}")  // 处理GET请求
    @Operation(summary = "根据ID获取轮播图", description = "根据轮播图ID获取单个轮播图的详细信息")  // API描述  
    public Result<Banner> getBannerById(@Parameter(description = "轮播图ID") @PathVariable Long id) {
        //根据ID查询即可
        Banner banner = bannerService.getById(id);
        //进行结果拼接
        if (banner != null) {
            log.info("查询轮播图业务执行成功！结果为：{}", banner);
            return Result.success(banner, "查询轮播图成功");
        }
        log.info("查询轮播图业务执行失败！结果为：{}", id);
        return Result.error("轮播图详情查询失败");


    }

    /**
     * 添加轮播图
     *
     * @param banner 轮播图对象
     * @return 操作结果
     */
    @PostMapping("/add")  // 处理POST请求
    @Operation(summary = "添加轮播图", description = "创建新的轮播图，需要提供图片URL、标题、跳转链接等信息")  // API描述
    public Result<String> addBanner(@RequestBody Banner banner) throws Exception {
        bannerService.addBanner(banner);
        log.info("轮播图保存数据业务调用成功！");
        return Result.success("轮播图数据保存成功！");
    }

    /**
     * 更新轮播图
     *
     * @param banner 轮播图对象
     * @return 操作结果
     */
    @PutMapping("/update")  // 处理PUT请求
    @Operation(summary = "更新轮播图", description = "更新轮播图的信息，包括图片、标题、跳转链接、排序等")  // API描述
    public Result<String> updateBanner(@RequestBody Banner banner) throws Exception {
        bannerService.updateBanner(banner);
        log.info("轮播图更新数据业务调用成功！");
        return Result.success("轮播图数据更新成功！");

    }

    /**
     * 删除轮播图
     *
     * @param id 轮播图ID
     * @return 操作结果
     */
    @DeleteMapping("/delete/{id}")  // 处理DELETE请求
    @Operation(summary = "删除轮播图", description = "根据ID删除指定的轮播图")  // API描述
    public Result<String> deleteBanner(@Parameter(description = "轮播图ID") @PathVariable Long id) {
        //直接删除
        boolean removed = bannerService.removeById(id);
        if (removed) {
            log.info("删除轮播图业务执行成功！删除id为:{}", id);
            return Result.success("删除数据成功");
        }
        log.info("删除轮播图业务执行失败！删除id为:{}", id);
        return Result.error("删除轮播图数据失败!");
    }

    /**
     * 启用/禁用轮播图
     *
     * @param id       轮播图ID
     * @param isActive 是否启用
     * @return 操作结果
     */
    @PutMapping("/toggle/{id}")  // 处理PUT请求
    @Operation(summary = "切换轮播图状态", description = "启用或禁用指定的轮播图，禁用后不会在前台显示")  // API描述
    public Result<String> toggleBannerStatus(
            @Parameter(description = "轮播图ID") @PathVariable Long id,
            @Parameter(description = "是否启用，true为启用，false为禁用") @RequestParam Boolean isActive) {
        //创建updaateWrapper
        LambdaUpdateWrapper<Banner> LambdaUpdateWrapper = new LambdaUpdateWrapper<Banner>();
        //设置修改的值 id = x
        LambdaUpdateWrapper.eq(Banner::getId, id);
        //设置修改的值 isActive = x
        LambdaUpdateWrapper.set(Banner::getIsActive, isActive);
        boolean update = bannerService.update(LambdaUpdateWrapper);
        if (update) {
            log.info("切换轮播图状态业务执行成功！id为:{}", id);
            return Result.success("轮播图状态切换成功！");
        }
        log.info("切换轮播图状态业务执行失败！id为:{}", id);
        return Result.error("轮播图状态切换失败！");

    }
} 